PATENTS 
112056-0009 
P01-1093 

IN THE CLAIMS: 

Please cancel Claims 1, 3-5, 10-15, 35-36, 43, and 54-55 without prejudice, 
l 1. (Cancelled) 

1 2. (Previously Presented) The method of Claim 6 wherein the step of associating 

2 comprises the step of producing a result representing a remainder upon dividing the IP ID 

3 by the number of active links. 

l 3.-5. (Cancelled) 

1 6. (Previously Presented) A method for uniformly distributing data transmitted by a 

2 server over a plurality of underlying links of an aggregate within a computer network, 

3 comprising: 

4 defining a unit of data as a datagram; 

5 apportioning each datagram into at least one fragment at the server; 

6 associating each fragment to an underlying link of the aggregate on the basis of an 

7 Internet protocol (IP) identifier (ID) of each datagram and a number of active links of the 

8 aggregate, wherein the step of associating includes: 

9 logically combining the IP ID with a predetermined mask to produce a quantity, 

10 right shifting the quantity a predetermined number of places, 

n establishing a threshold at which a group of data is forwarded to each underlying 

12 link of the aggregate, 
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13 producing a result representing a remainder upon dividing the right shifted logi- 

14 cally combined quantity IP ID and predetermined mask by the number of active links, 

15 wherein the IP ID is a 16-bit value, the predetermined mask is 0xFF80 and predetermined 

16 number of right shifted places is 7, and wherein the group of data comprises 128 IP IDs; 

n transmitting the fragment over its associated underlying link from the server to the 

is computer network. 

1 7. (Original) The method of Claim 6 wherein the group of data comprises one of 128 

2 different transport control protocol (TCP) fragments and 128 different user datagram pro- 

3 tocol (UDP) datagrams. 

1 8. (Original) The method of Claim 7 wherein each UDP datagram comprises up to 

2 23 fragments. 

1 9. (Previously Presented) The method of Claim 1 further comprising: 

2 loading at least one data buffer of the server with the at least one fragment; 

3 fetching the fragment from the data buffer; and 

4 loading at least one queue of the server with the fragment, the queue associated 

5 with the underlying link. 

l 10.-15.(Cancelled) 

l 16. (Previously Presented) A computer readable medium, comprising: 
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2 the medium storing executable program instructions for uniformly distributing 

3 data transmitted by a server over a plurality of underlying links of an aggregate within a 

4 computer network, the executable program instructions having program instructions for: 

5 defining a unit of data as a datagram; 

6 apportioning each datagram into at least one fragment at the server; 

7 associating each fragment to an underlying link of the aggregate on the basis of an 

8 Internet protocol (IP) identifier (ID) of each datagram and a number of active links of the 

9 aggregate, wherein the step of associating includes: 

10 logically combining the IP ID with a predetermined mask to produce a quantity, 
n right shifting the quantity a predetermined number of places, 

12 establishing a threshold at which a group of data is forwarded to each underlying 

13 link of the aggregate, 

14 producing a result representing a remainder upon dividing the right shifted logi- 

15 cally combined quantity IP ID and predetermined mask by the number of active links, 

16 wherein the IP ID is a 16-bit value, the predetermined mask is 0xFF80 and predetermined 
n number of right shifted places is 7, and wherein the group of data comprises 128 IP IDs; 

is transmitting the fragment over its associated underlying link from the server to the 

19 computer network. 

1 17. (Original) The computer readable medium of Claim 16 wherein the program in- 

2 struction for associating comprises a program instruction for producing a result represent- 

3 ing a remainder upon dividing the IP ID by the number of active links. 

1 18. (Original) The computer readable medium of Claim 17 wherein the program in- 

2 struction for associating further comprises program instructions for: 
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calculating the IP ID of each datagram in a sequential manner; and 

rotating the fragments of each datagram among all the underlying links to thereby 
ensure that all fragments having the same IP ID are provided to the same physical link of 
the aggregate. 

19. (Original) The computer readable medium of Claim 16 wherein the program in- 
struction for associating comprises program instructions for: 

logically combining the IP ID with a predetermined mask to produce a quantity; 

right shifting the quantity a predetermined number of places; and 

establishing a threshold at which a group of data is forwarded to each underlying link of 
the aggregate. 

20. (Original) The computer readable medium of Claim 19 wherein the program in- 
struction for associating further comprises the program instruction for producing a result 
representing a remainder upon dividing the right shifted logically combined quantity IP 
ID and predetermined mask by the number of active links 

21 . (Previously Presented) A method for distributing data over a plurality of network 
links within a computer network, comprising: 

providing the plurality of links as a connection to a network node; 

selecting one link of the plurality of links for transmitting a datagram to the net- 
work node (hereinafter the selected link) using a round robin selection technique, the data 
identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point 
destination for the data; 

apportioning the datagram into at least one fragment; 
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associating the datagram to a network link of the plurality of network links ac- 
cording to a round robin policy based at least in part on the IP ID; 

associating each fragment to the selected link on the basis of the IP ID; and 

transmitting the fragment over its associated link to transmit fragments of the data 
over the same associated link 

22. (Previously Presented) The method of claim 21 wherein the step of associating is 
further based, at least in part, on a number of network links in the plurality of links. 

23. (Previously Presented) The method of claim 22 wherein the step of associating 
comprises: 

producing a result representing a remainder by dividing the IP ID by the number 
of network links. 

24. (Previously Presented) The method of claim 23 wherein the step of associating 
further comprises: 

calculating the IP ID of each datagram in a sequential manner; and 

rotating the fragments of each datagram among all the network links of the plural- 
ity of network links to thereby ensure that all fragments having the same IP ID are pro- 
vided to the same network link. 

25. (Previously Presented) The method of claim 21 wherein the step of associating 
comprises: 

logically combining the IP ID with a predetermined mask to produce a quantity; 
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right shifting the quantity by a predetermined number of places to create a Previ- 
ously Presented quantity; and 

establishing a threshold at which a group of data is forwarded to each network 
link of the plurality of network links. 

26. (Previously Presented) The method of claim 25 wherein the step of associating 
further comprises the step of producing a result representing a remainder upon dividing 
the Previously Presented quantity by a number of network links in the plurality of net- 
work links. 

27. (Previously Presented) A system for distributing data over a plurality of network 
links within a computer network comprising: 

a processor; 

a memory coupled to the processor and having locations addressable by the proc- 
essor; 

an operating system resident in the memory locations and executed by the proces- 
sor, the operating system configured to implement a load balancing technique that defines 
a unit of data as a datagram, the operating system further configured to include an Inter- 
net Protocol (IP) layer that apportions the datagram into at least one fragment, the operat- 
ing system further configured to include a virtual interface process that associates each 
datagram to a network link of the plurality of network links according to a round robin 
policy based at least in part on an Internet protocol (IP) identifier (ID) of each datagram; 
and 

at least one network adapter coupled to the memory and processor to transmit the 
fragments of the datagram over the datagram's associated network link. 
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28. (Currently Amended) A system for distributing data over a plurality of network 
links within a computer network, comprising: 

means for providing the plurality of links as a connection to a network node; 

means for selecting one link of the plurality of links for transmitting a datagram to 
the network node (hereinafter the selected link) using a round robin selection technique, 
the data identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end 
point destination for the data; 

means for defining a unit of data as a datagram; 

means for apportioning the each datagram into a plurality of fragments at least 
one fragment ; 

means for associating each datagram to a network link of the plurality of network 
links according to a round robin policy based at least in part on an Internet protocol (IP) 
identifier (ID) of each datagram; 

means for associating each fragment of the plurality of fragments to the selected 
link on the basis of the IP ID; and 

means for transmitting the plurality of fragments over its associated link to trans- 
mit fragments of the data over the same associated link 

means for transmitting the fragments of the datagram over the datagram's associ 
ated network link . 

29. (Previously Presented) A computer readable medium, comprising: 
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2 the medium storing executable program instructions for execution on a processor, 

3 the executable program instructions having program instructions for: 

4 providing the plurality of links as a connection to a network node; 

5 selecting one link of the plurality of links for transmitting a datagram to the net- 

6 work node (hereinafter the selected link) using a round robin selection technique, the data 

7 identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point 

8 destination for the data; 

9 apportioning the datagram into at least one fragment; 

10 associating the datagram to a network link of the plurality of network links ac- 
n cording to a round robin policy based at least in part on the IP ID; 

12 associating each fragment to the selected link on the basis of the IP ID; and 

13 transmitting the fragment over its associated link to transmit fragments of the data 

14 over the same associated link. 

1 30. (Previously Presented) A method for distributing data over a plurality of network 

2 links within a computer network, comprising: 

3 aggregating the plurality of network links to provide a connection to a network 

4 node, each link of the plurality of links assigned to the same MAC address of the network 

5 node; 

6 dividing a first datagram, having a first Internet protocol (IP) identifier (ID), into 

7 one or more fragments, each fragment of the first datagram associated with the first 

8 Internet protocol (IP) identifier (ID); 

9 selecting a first network link of the plurality of network links for transmission of 

10 the one or more fragments of the first datagram, the selection done by a round robin pol- 
n icy; 
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transmitting all of the one or more fragments associated with the first IP ID over 
the first network link; 

dividing a second datagram, having a second Internet protocol (IP) identifier (ID), 
into one or more fragments, each fragment of the second datagram associated with the 
second Internet protocol (IP) identifier (ID); 

selecting a second network link of the plurality of network links for transmission 
of the one or more fragments of the second datagram; and 

transmitting all of the one or more fragments associated with the second IP ID 
over the second network link. 

31. (Previously Presented) The method of claim 30 wherein the first network link and 
the second network link are selected according to a round robin policy based on the IP ID 
of each datagram. 

32. (Previously Presented) A system for distributing data over a plurality of network 
links within a computer network comprising: 

a processor; 

a memory coupled to the processor and having locations accessible by the proces- 
sor; 

a virtual interface aggregating the plurality of network links to provide a connec- 
tion to a network node, each link of the plurality of links assigned to the same MAC ad- 
dress of the network node; 

an operating system resident in the memory and executed by the processor, the 
operating system configured to implement a load balancing technique that divides a first 
datagram, having a first Internet protocol (IP) identifier (ID), into one or more fragments, 
each fragment of the first datagram associated with the first Internet protocol (IP) identi- 
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fier (ID), select a first network link of the plurality of network links for transmission of 
the one or more fragments of the first datagram, the selection done by round robin policy, 
transmit all of the one or more fragments associated with the first IP ID over the first 
network link, divide a second datagram, having a second Internet protocol (IP) identifier 
(ID), into one or more fragments, each fragment of the second datagram associated with a 
second Internet protocol (IP) identifier (ID), select a second network link of the plurality 
of network links for transmission of the one or more fragments of the second datagram, 
and transmit all of the one or more fragments associated with the second IP ID over the 
second network link. 

33. (Previously Presented) The system of claim 32 wherein the first network link and 
the second network link are selected according to a round robin policy based on the IP ID 
of each datagram. 

34. (Previously Presented) The method of claim 6 wherein the step of associating fur- 
ther comprises apportioning data equally over the plurality of underlying links of the ag- 
gregate within the computer network. 

35. -36.(Cancelled) 

37. (Previously Presented) The system of claim 27 wherein the round robin policy is 
further based, at least in part, on a number of network links in the plurality of links. 

38. (Previously Presented) The system of claim 27 wherein the virtual interface proc- 
ess is configured to produce a result representing a remainder by dividing the IP ID by 
the number of network links. 
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39. (Previously Presented) The method of claim 38 wherein the virtual interface proc- 
ess is further configured to calculate the IP ID of each datagram in a sequential manner 
and to rotate the fragments of each datagram among all the network links of the plurality 
of network links to thereby ensure that all fragments having the same IP ID are provided 
to the same network link. 

40. (Previously Presented) The system of claim 27 wherein the virtual interface proc- 
ess is configured to logically combine the IP ID with a predetermined mask to produce a 
quantity, right shift the quantity by a predetermined number of places to create a Previ- 
ously Presented quantity, and establish a threshold at which a group of data is forwarded 
to each network link of the plurality of network links. 

41. (Previously Presented) The system of claim 40 wherein the virtual interface proc- 
ess is further configured to produce a result representing a remainder upon dividing the 
Previously Presented quantity by a number of network links in the plurality of network 
links. 

42. (Previously Presented) The method of claim 30, wherein the steps of transmitting 
are performed in parallel. 

43. (Cancelled) 

44. (Previously Presented) A method for uniformly distributing data transmitted by a 
server over a number of underlying links of an aggregate within a computer network, the 
comprising: 

providing the plurality of links as a connection to a network node; 
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selecting one link of the plurality of links for transmitting a datagram to the net- 
work node (hereinafter the selected link) using a round robin selection technique, the data 
identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point 
destination for the data; 

apportioning the datagram into at least one fragment; 

associating the fragments with the selected link; and 
transmitting the fragments over the selected link. 

45. (Previously Presented) The method of claim 44 wherein the step of calculating 
further comprises: 

dividing the IP ID by the number of underlying links to generate a remainder; and 
using the remainder to select the selected link. 

46. (Previously Presented) The method of claim 44 wherein the step of calculating 
further comprises: 

performing a logical AND operation to combine the IP ID and a predetermined 

mask; 

dividing the result of the logical AND operation by the number of underlying 
links to generate a remainder; and 

using the remainder as the link identifier. 

47. (Previously Presented) The method of claim 46 wherein the predetermined mask 
is 0xFF80. 
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48. (Previously Presented) The method of claim 44 wherein the step of calculating 
further comprises: 

performing a logical AND operation to combine the IP ID and a predetermined 

mask; 

right shifting the result of the logical AND by a predetermined number of bits; 

dividing the result of right shifting by the number of underlying links to generate 
a remainder; and 

using the remainder as the link identifier. 

49. (Previously Presented) The method of claim 48 wherein the predetermined mask 
is 0xFF80 and the predetermined number of bits is 7 bits. 

50. (Previously Presented) An apparatus for uniformly distributing data transmitted 
by a server over a number of underlying links of an aggregate within a computer network, 
comprising: 

means for providing the plurality of links as a connection to a network node; 

means for selecting one link of the plurality of links for transmitting a datagram to 
the network node (hereinafter the selected link) using a round robin selection technique, 
the data identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end 
point destination for the data; 

means for apportioning the datagram into at least one fragment; 

means for associating the fragments with the selected link; and 
means for transmitting the fragments over the selected link. 
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51. (Previously Presented) A computer readable medium storing executable program 
instructions for uniformly distributing data transmitted by a server over a plurality of un- 
derlying links of an aggregate within a computer network, the executable program in- 
structions comprising program instructions for: 

providing the plurality of links as a connection to a network node; 

selecting one link of the plurality of links for transmitting a datagram to the net- 
work node (hereinafter the selected link) using a round robin selection technique, the data 
identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point 
destination for the data; 

defining a unit of data as a datagram; 

apportioning the datagram into at least one fragment; 
associating the fragments with the selected link; and 
transmitting the fragments over the selected link. 

52. (Previously Presented) A method for uniformly distributing data transmitted by a 
server over a number of underlying links of an aggregate within a computer network, 
comprising: 

providing the number of underlying links from the server as a connection to a 
network node; 

selecting one link of the plurality of links for transmitting data from the server to 
the network node (hereinafter the selected link) using a round robin selection technique, 
the data identified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end 
point destination for the data; 

selecting a datagram for transmission, the datagram having-an the Internet proto- 
col (IP) identifier (ID); 

breaking the datagram into fragments; and 
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sending all of the fragments down the selected link. 

53. (Previously Presented) The method of claim 52, further comprising: 

calculating a link identifier for the datagram as a function of the IP ID and the 
number of underlying links; 

associating the fragments with the link identifier; and 

transmitting the fragments over a link identified by the link identifier. 

54. -55. (Cancelled) 

56. (Previously Presented) A method for distributing data over a plurality of network 
links, comprising: 

providing the plurality of links as a connection to a network node; 

selecting one link of the plurality of links for transmitting the data to the network 
node (hereinafter the selected link) using a round robin selection technique, the data iden- 
tified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point desti- 
nation for the data; 

apportioning the data into at least one fragment; 

associating each fragment to the selected link on the basis of the IP ID; and 

transmitting the fragment over its associated link to transmit fragments of the data 
over the same associated link. 

57. (Previously Presented) The method of claim 56, further comprising: 
obtaining a second data to transmit over the plurality of links; and 
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selecting by the round robin process a second link to transmit fragments of the 
second data to the network node. 

58. (Previously Presented) The method of claim 56, further comprising: 
directing each link of the plurality of links to a common media access address 

(MAC address). 

59. (Previously Presented) A computer, comprising: 

a plurality of links to provide a connection to a network node; 

one link of the plurality of links selected for transmitting a data to the network 
node (hereinafter the selected link) using a round robin selection technique, the data iden- 
tified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point desti- 
nation for the data; 

a processor to apportion the data into at least one fragment; 

software to associate each fragment to the selected link on the basis of the IP ID; 

and 

a port to transmit the fragment over its associated link to transmit fragments of the 
data over the same associated link. 

60. (Previously Presented) The computer as in claim 59, further comprising: 

a second data, the second data to be transmitted over the plurality of links; and 

the round robin process to select a second link to transmit fragments of the second 
data to the network node. 
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a common media access address (MAC address) to which each link of the plural- 
ity of links is directed. 

62. (Previously Presented) A computer readable media, comprising: 

said computer readable media containing instructions for execution on a processor 
for a method of distributing data over a plurality of network links, the method having the 
steps of: 

providing the plurality of links as a connection to a network node; 

selecting one link of the plurality of links for transmitting the data to the network 
node (hereinafter the selected link) using a round robin selection technique, the data iden- 
tified by an Internet protocol (IP) identifier (ID), the IP ID indicating an end point desti- 
nation for the data; 

apportioning the data into at least one fragment; 

associating each fragment to the selected link on the basis of the IP ID; and 

transmitting the fragment over its associated link to transmit fragments of the data 
over the same associated link. 
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